Microsoft Technologies ADO.NET এবং Entity Framework ব্যবহার করে Database Access গাইড ও নোট

251

ADO.NET এবং Entity Framework (EF) উভয়ই .NET ফ্রেমওয়ার্কে ডেটাবেস অ্যাক্সেসের জন্য ব্যবহৃত শক্তিশালী টুল। ADO.NET একটি লো-লেভেল API যা ডেটাবেসের সাথে সরাসরি কাজ করে, এবং Entity Framework একটি ORM (Object-Relational Mapping) প্রযুক্তি যা ডেটাবেসের সাথে অবজেক্ট ভিত্তিক ইন্টারঅ্যাকশন সরবরাহ করে।

এই দুটি প্রযুক্তি ডেটাবেসের সাথে যোগাযোগ স্থাপন, ডেটা অনুসন্ধান, যোগ করা, আপডেট করা এবং মুছতে সহায়তা করে। এখানে আমরা ADO.NET এবং Entity Framework এর মাধ্যমে ডেটাবেস অ্যাক্সেস করার মৌলিক ধারণা এবং উদাহরণ আলোচনা করব।


ADO.NET দিয়ে Database Access

ADO.NET একটি ডেটাবেস অ্যাক্সেস প্রযুক্তি যা ডেটাবেসের সাথে সংযোগ স্থাপন, কুয়েরি চালানো এবং ডেটা পেতে বা প্রেরণ করতে ব্যবহৃত হয়। ADO.NET সরাসরি SQL কুয়েরি ব্যবহার করে ডেটাবেসের সাথে কাজ করে।

ADO.NET দিয়ে SQL Server এর সাথে সংযোগ স্থাপন

  1. Connection: ডেটাবেসের সাথে সংযোগ স্থাপন করতে SqlConnection ব্যবহার করা হয়।
  2. Command: SQL কুয়েরি চালানোর জন্য SqlCommand ব্যবহার করা হয়।
  3. DataReader: কুয়েরির ফলাফল ডাটাবেস থেকে পেতে SqlDataReader ব্যবহার করা হয়।

ADO.NET উদাহরণ: SQL Server এ ডেটা রিড করা

using System;
using System.Data.SqlClient;

class Program
{
    static void Main()
    {
        string connectionString = "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;";

        using (SqlConnection connection = new SqlConnection(connectionString))
        {
            connection.Open();
            string query = "SELECT * FROM Customers";

            using (SqlCommand command = new SqlCommand(query, connection))
            {
                using (SqlDataReader reader = command.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        Console.WriteLine($"ID: {reader["CustomerID"]}, Name: {reader["CustomerName"]}");
                    }
                }
            }
        }
    }
}

ব্যাখ্যা:

  • SqlConnection দিয়ে SQL Server ডেটাবেসের সাথে সংযোগ স্থাপন করা হয়েছে।
  • SqlCommand এর মাধ্যমে SELECT কুয়েরি চালানো হয়েছে।
  • SqlDataReader ব্যবহার করে ডেটাবেস থেকে ফলাফল রিড করা হয়েছে।

Entity Framework দিয়ে Database Access

Entity Framework (EF) হলো একটি ORM (Object-Relational Mapping) প্রযুক্তি যা ডেটাবেসের সাথে অবজেক্ট ভিত্তিক সম্পর্ক স্থাপন করে। এটি SQL কুয়েরি লেখার পরিবর্তে ডাটাবেসের সাথে কাজ করতে C# কোডের মাধ্যমে অবজেক্ট মডেল তৈরি করে।

Entity Framework তে Database Context তৈরি

EF তে DbContext ব্যবহার করে ডেটাবেসের সাথে যোগাযোগ করা হয়। আপনি DbSet ব্যবহার করে একটি টেবিলের ডেটাকে প্রতিনিধিত্ব করেন, এবং LINQ ব্যবহার করে ডেটা কুয়েরি করতে পারেন।

Entity Framework উদাহরণ: SQL Server এ ডেটা রিড করা

  1. Model Class: প্রথমে ডেটাবেস টেবিলের জন্য একটি ক্লাস মডেল তৈরি করতে হয়।
  2. DbContext Class: এই ক্লাসে ডেটাবেসের সাথে সংযোগ স্থাপন এবং টেবিলের সাথে যোগাযোগ করা হয়।
using System;
using System.Linq;
using Microsoft.EntityFrameworkCore;

public class Customer
{
    public int CustomerID { get; set; }
    public string CustomerName { get; set; }
}

public class ApplicationDbContext : DbContext
{
    public DbSet<Customer> Customers { get; set; }

    protected override void OnConfiguring(DbContextOptionsBuilder options)
        => options.UseSqlServer("Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;");
}

class Program
{
    static void Main()
    {
        using (var context = new ApplicationDbContext())
        {
            var customers = context.Customers.ToList();

            foreach (var customer in customers)
            {
                Console.WriteLine($"ID: {customer.CustomerID}, Name: {customer.CustomerName}");
            }
        }
    }
}

ব্যাখ্যা:

  • Customer ক্লাস ডেটাবেসের Customers টেবিলের প্রতিনিধিত্ব করে।
  • ApplicationDbContext ক্লাসটি DbContext ইনহেরিট করে এবং টেবিলের সাথে যোগাযোগের জন্য DbSet ব্যবহার করে।
  • ToList() মেথড ব্যবহার করে Customers টেবিল থেকে সমস্ত রেকর্ড রিট্রাইভ করা হয়েছে।

ADO.NET এবং Entity Framework মধ্যে পার্থক্য (Differences Between ADO.NET and Entity Framework)

FeatureADO.NETEntity Framework
Programming ModelProcedural (SQL queries with objects)Object-oriented (Models and DbContext)
Level of AbstractionLow-level API, direct SQL interactionHigh-level abstraction using LINQ
Data RetrievalManual handling of results (DataReader)Automatic mapping from database to objects
PerformanceBetter for performance with complex queriesSlightly slower for simple queries due to abstraction
ComplexityMore code to write for data accessLess code, easier to manage
Code MaintenanceRequires more managementEasier to maintain with object-oriented approach
SQL Query UsageDirect SQL queriesNo direct SQL needed, uses LINQ queries

Advantages of Entity Framework over ADO.NET

  1. Code-First Approach: EF allows you to define your data model in C# code and generate the database schema automatically.
  2. Object-Oriented: EF works directly with objects and abstracts the underlying SQL, making it easier to interact with the data.
  3. LINQ Support: EF provides LINQ support, allowing developers to write queries using C# syntax instead of SQL.
  4. Database Independence: With EF, the application can work with multiple database providers (e.g., SQL Server, SQLite, MySQL) with minimal changes in code.

Conclusion

ADO.NET এবং Entity Framework উভয়ই ডেটাবেস অ্যাক্সেসের জন্য কার্যকরী টুলস। ADO.NET যেখানে ডেটাবেসের সাথে সরাসরি SQL কুয়েরি চালানোর মাধ্যমে কাজ করে, সেখানে Entity Framework একটি উচ্চ স্তরের ORM টুল যা অবজেক্ট-ভিত্তিক ডেটাবেস ইন্টারঅ্যাকশন সরবরাহ করে। আপনি যেভাবে অ্যাপ্লিকেশন তৈরি করতে চান, তাতে ADO.NET দ্রুত এবং কার্যকরী হলেও Entity Framework আরও পরিষ্কার এবং কম্প্যাক্ট কোড প্রদান করে।

Content added By
Promotion

Are you sure to start over?

Loading...